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Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in the application: 
Listing of Claims: 

1 . (Original) A system for finding a longest prefix match for a key in a computer 
network, the system comprising: 

a main engine for storing a first plurality of addresses and for searching the first plurality 
of addresses for the longest prefix match for the key, none of the first plurality of addresses being 
a prefix for another address of the first plurality of addresses; and 

an auxiliary engine for storing and searching a second plurality of addresses, a first 
address of the second plurality of addresses capable of including the prefix for a second address 
of the first plurality of addresses or for a third address for the second plurality of addresses, none 
of the first plurality of addresses being the prefix for any of the second plurality of addresses, 
each of the second plurality of addresses being distinct from each of the first plurality of 
addresses. 

2. (Original) The system of claim 1 wherein each of the first plurality of addresses has a 
first length, each of the second plurality of addresses has a second length and wherein the key is 
capable of having a maximum length, the first length being at least a particular portion of the 
maximum length. 
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3. (Original) The system of claim 2 wherein the main engine does not search the first 
plurality of addresses if an actual length of the key is less than the particular portion of the 
maximum length. 

4. (Original) The system of claim 2 wherein the maximum length is thirty-two bits and 
wherein the first length is sixteen bits. 

5. (Original) The system of claim 1 wherein the auxiliary engine searches the second 
plurality of addresses only if the longest prefix match is not found in the main engine. 

6. (Original) The system of claim 1 wherein a new address is added to the first plurality 
of addresses if the new address is not the prefix of any of the first plurality of addresses and the 
new address has a length that is greater than a particular length or if the new address has a length 
that is greater than a particular length, a particular address of the first plurality of addresses is a 
prefix of the new address and the length of the new address is greater than an address length of 
the particular entry. 

7. (Original) The system of claim 1 wherein if a particular address of the first plurality of 
addresses is deleted, then a replacement address from the second plurality of addresses in the 
auxiliary engine is moved to the main engine if the replacement address is a prefix of the 
particular address, the replacement address has a length greater than a particular length and the 
length of the address is not shorter than an index for a next bit to test corresponding to an 
adjacent address next to the particular addresses in the main engine. 
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8. (Original) The system of claim 1 wherein the main engine is a direct table having a 
plurality of table addresses and wherein each of the plurality of table addresses includes a tree. 

9. (Original) The system of claim 8 wherein the tree is a Patricia tree. 

10. (Original) A method for providing a mechanism for finding a longest prefix match 
for a key in a computer network, the method comprising the steps of: 

(a) providing a main engine for storing a first plurality of addresses and for searching 
the first plurality of addresses for the longest prefix match for the key, none of the first plurality 
of addresses being a prefix for another address of the first plurality of addresses; and 

(b) providing an auxiliary engine for storing and searching a second plurality of 
addresses, a first address of the second plurality of addresses capable of including the prefix for a 
second address of the first plurality of addresses or for a third address for the second plurality of 
addresses, none of the first plurality of addresses being the prefix for any of the second plurality 
of addresses, each of the second plurality of addresses being distinct from each of the first 
plurality of addresses. 

1 1. (Original) The method of claim 10 wherein each of the first plurality of addresses 
has a first length, each of the second plurality of addresses has a second length and wherein the 
key is capable of having a maximum length, the first length being at least a particular portion of 
the maximum length. 
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12. (Original) The method of claim 1 1 wherein the main engine does not search the first 
plurality of addresses if an actual length of the key is less than the particular portion of the 
maximum length. 

13. (Original) The method of claim 1 1 wherein the maximum length is thirty-two bits 
and wherein the first length is sixteen bits. 

14. (Original) The method of claim 10 wherein the auxiliary engine searches the second 
plurality of addresses only if the longest prefix match is not found in the main engine. 

15. (Original) The method of claim 10 wherein a new address is added to the first 
plurality of addresses if the new address is not the prefix of any of the first plurality of addresses 
and the new address has a length that is greater than a particular length or if the new address has 
a length that is greater than a particular length, a particular address of the first plurality of 
addresses is a prefix of the new address and the length of the new address is greater than an 
address length of the particular entry. 

16. (Original) The method of claim 10 wherein if a particular address of the first 
plurality of addresses is deleted, then a replacement address from the second plurality of 
addresses in the auxiliary engine is moved to the main engine if the replacement address is a 
prefix of the particular address, the replacement address has a length greater than a particular 
length and the length of the address is not shorter than an index for a next bit to test 
corresponding to an adjacent address next to the particular addresses in the main engine. 
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17. (Original) The method of claim 1 1 wherein the step of providing the main engine (a) 
further includes the step of: 

(al) providing a direct table having a plurality of table addresses and wherein each of 
the plurality of table addresses includes a tree. 

1 8. (Original) The method of claim 17 wherein the tree is a Patricia tree. 

19. (Original) A method for determining a longest prefix match for a key in a computer 
network, the method comprising the steps of: 

(a) searching a main engine for the longest prefix match, the main engine storing a 
first plurality of addresses and for searching the first plurality of addresses for the longest prefix 
match for the key, none of the first plurality of addresses being a prefix for another address of the 
first plurality of addresses; and 

(b) searching an auxiliary engine for the longest prefix match only if the longest 
prefix match is not found in the main engine, the auxiliary engine for storing and searching a 
second plurality of addresses, an entry of the second plurality of addresses capable of including 
the prefix for an address of the first plurality of addresses or for a second address for the second 
plurality of addresses, none of the first plurality of addresses being the prefix for any of the 
second plurality of addresses, each of the second plurality of addresses being distinct from each 
of the first plurality of addresses. 
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20. (Original) A computer-readable medium containing a program for providing a 
mechanism for finding a longest prefix match for a key in a computer network, the program 
including instructions for: 

(a) providing a main engine for storing a first plurality of addresses and for searching 
the first plurality of addresses for the longest prefix match for the key, none of the first plurality 
of addresses being a prefix for another address of the first plurality of addresses; and 

(b) providing an auxiliary engine for storing and searching a second plurality of 
addresses, a first address of the second plurality of addresses capable of including the prefix for a 
second address of the first plurality of addresses or for a third address for the second plurality of 
addresses, none of the first plurality of addresses being the prefix for any of the second plurality 
of addresses, each of the second plurality of addresses being distinct from each of the first 
plurality of addresses. 

21 . (Original) A computer-readable medium containing a program for determining a 
longest prefix match for a key in a computer network, the program including instructions for: 

(a) searching a main engine for the longest prefix match, the main engine storing a 
first plurality of addresses and for searching the first plurality of addresses for the longest prefix 
match for the key, none of the first plurality of addresses being a prefix for another address of the 
first plurality of addresses; and 

(b) searching an auxiliary engine for the longest prefix match only if the longest 
prefix match is not found in the main engine, the auxiliary engine for storing and searching a 
second plurality of addresses, an entry of the second plurality of addresses capable of including 
the prefix for an address of the first plurality of addresses or for a second address for the second 
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plurality of addresses, none of the first plurality of addresses being the prefix for any of the 
second plurality of addresses, each of the second plurality of addresses being distinct from each 
of the first plurality of addresses. 

Please add claims: 

22. (New) The system of claim 1 wherein the auxiliary engine is configured to be 
searched only if the longest prefix match for the key is not found in the main engine. 

23. (New) The method of claim 10 wherein the auxiliary engine is configured to be 
searched only if the longest prefix match for the key is not found in the main engine. 

24. (New) The computer-readable medium of claim 20 wherein the auxiliary engine is 
configured to be searched only if the longest prefix match for the key is not found in the main 
engine. 
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